## **ARM M Series Processor**

We would use one of these for a system with one or very few services. The example provided suggest to use for an automotive braking subsystem, for this application I would choose a cyclic executive, just a main loop in C is simple and deterministic in this simple processors making it easier to debug and understand. As for the choice of the processor it depends on our needs and budget, see table in next slide:

## TABLE Comparing Different ARM Series Processors

| Feature                                         | Cortex-<br>M0    | Cortex-<br>M0+   | Cortex-<br>M1 | Cortex-<br>M23      | Cortex-<br>M3    | Cortex-<br>M4    | M33                 | Cortex-<br>M35P     | Cortex-<br>M55        | Cortex-<br>M7 |
|-------------------------------------------------|------------------|------------------|---------------|---------------------|------------------|------------------|---------------------|---------------------|-----------------------|---------------|
| Instruction<br>Set<br>Architecture              | Armv6-M          | Armv6-M          | Armv6-M       | Armv8-M<br>Baseline | Armv7-M          | Armv7-M          | Armv8-M<br>Mainline | Armv8-M<br>Mainline | Armv8.1-M<br>Mainline | Armv7-M       |
| TrustZone<br>for Armv8-M                        | No               | No               | No            | Yes (option)        | No               | No               | Yes (option)        | Yes (option)        | Yes (option)          | No            |
| Digital Signal<br>Processing<br>(DSP) Extension | No               | No               | No            | No                  | No               | Yes              | Yes                 | Yes                 | Yes                   | Yes           |
| Hardware<br>Divide                              | No               | No               | No            | Yes                 | Yes              | Yes              | Yes                 | Yes                 | Yes                   | Yes           |
| Arm Custom<br>Instructions                      | No               | No               | No            | No                  | No               | No               | Yes                 | No                  | Yes                   | No            |
| Coprocessor<br>Interface                        | No               | No               | No            | No                  | No               | No               | Yes                 | Yes                 | Yes                   | No            |
| DMIPS/MHz*                                      | 0.87             | 0.95             | 0.8           | 0.98                | 1.25             | 1.25             | 1.5                 | 1.5                 | 1.6                   | 2.14          |
| CoreMark®/<br>MHz*                              | 2.33             | 2.46             | 1.85          | 2.64                | 3.34             | 3.42             | 4.02                | 4.02                | 4.2                   | 5.01          |
| Maximum<br># External<br>Interrupts             | 32               | 32               | 32            | 240                 | 240              | 240              | 480                 | 480                 | 480                   | 240           |
| Maximum<br>MPU Regions                          | 0                | 8                | 0             | 16                  | 8                | 8                | 16                  | 16                  | 16                    | 16            |
| Bus Protocol                                    | AHB<br>Lite      | AHB<br>Lite      | AHB<br>Lite   | AHB5                | AHB<br>Lite      | AHB<br>Lite      | АНВ                 | AHB                 | AXI                   | AXI           |
| Instruction<br>Cache                            | No               | No               | No            | No                  | No               | No               | No                  | 2-16kB              | 0-64kB                | 0-64kB        |
| Data Cache                                      | No               | No               | No            | No                  | No               | No               | No                  | No                  | 0-64kB                | 0-64kB        |
| Instruction<br>TCM                              | No               | No               | No            | No                  | No               | No               | No                  | No                  | 0-16MB                | 0-16MB        |
| Data TCM                                        | No               | No               | No            | No                  | No               | No               | No                  | No                  | 0-16MB                | 0-16MB        |
| Dual Core<br>Lock-Step<br>(DCLS)                | No               | No               | No            | Yes                 | No               | No               | Yes                 | Yes                 | No                    | Yes           |
| Common<br>Criteria<br>Certification             | No               | No               | No            | No                  | No               | No               | Yes                 | Yes                 | No                    | No            |
| Reference<br>Package and/or<br>System Example   | Corstone<br>-101 | Corstone<br>-101 |               | Corstone<br>-102    | Corstone<br>-101 | Corstone<br>-101 | Corstone<br>-201    |                     | Corstone<br>-300      |               |

## Choosing a CPU

From the previous table I would go initially with a Cortex-M0 and only consider better CPUs if for some reason we need some extra features. However, we need: interrupts, caches, interrupts and DSP extensions.